/*
 *  Copyright 2020-2021 Li Fei
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *  http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 */
package com.pengshun.modules.api.coal.repository;

import com.pengshun.modules.domain.User;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
import org.springframework.data.jpa.repository.Modifying;
import org.springframework.data.jpa.repository.Query;

import java.util.Date;

/**
 * @author Li Fei
 * @date 2020年10月10日
 */
public interface UserRepository extends JpaRepository<User, Long>, JpaSpecificationExecutor<User> {

//    /**
//     * 根据用户名查询
//     * @param username 用户名
//     * @return /
//     */
//    User findByUsername(String username);
//
//    /**
//     * 根据邮箱查询
//     * @param email 邮箱
//     * @return /
//     */
//    User findByEmail(String email);
//

    User  findByPhone(String phone);

//    /**
//     * 修改邮箱
//     * @param username 用户名
//     * @param email 邮箱
//     */
//    @Modifying
//    @Query(value = "update sys_user set email = ?2 where username = ?1",nativeQuery = true)
//    void updateEmail(String username, String email);
//
//    /**
//     * 根据角色查询用户
//     * @param roleId /
//     * @return /
//     */
//    @Query(value = "SELECT u.* FROM sys_user u, sys_users_roles r WHERE" +
//            " u.user_id = r.user_id AND r.role_id = ?1", nativeQuery = true)
//    List<User> findByRoleId(Long roleId);
//
//    /**
//     * 根据角色中的部门查询
//     * @param id /
//     * @return /
//     */
//    @Query(value = "SELECT u.* FROM sys_user u, sys_users_roles r, sys_roles_depts d WHERE " +
//            "u.user_id = r.user_id AND r.role_id = d.role_id AND r.role_id = ?1 group by u.user_id", nativeQuery = true)
//    List<User> findByDeptRoleId(Long id);
//
//    /**
//     * 根据菜单查询
//     * @param id 菜单ID
//     * @return /
//     */
//    @Query(value = "SELECT u.* FROM sys_user u, sys_users_roles ur, sys_roles_menus rm WHERE\n" +
//            "u.user_id = ur.user_id AND ur.role_id = rm.role_id AND rm.menu_id = ?1 group by u.user_id", nativeQuery = true)
//    List<User> findByMenuId(Long id);
//
//    /**
//     * 根据Id删除
//     * @param ids /
//     */
//    void deleteAllByIdIn(Set<Long> ids);
//
//    /**
//     * 根据岗位查询
//     * @param ids /
//     * @return /
//     */
//    @Query(value = "SELECT count(1) FROM sys_user u, sys_users_jobs j WHERE u.user_id = j.user_id AND j.job_id IN ?1", nativeQuery = true)
//    int countByJobs(Set<Long> ids);
//
//    /**
//     * 根据商户类别查询
//     * @param ids /
//     * @return /
//     */
//    @Query(value = "SELECT count(1) FROM sys_user u, ps_users_merchant j WHERE u.user_id = j.user_id AND j.id IN ?1", nativeQuery = true)
//    int countByMerchant(Set<Long> ids);
//
//    /**
//     * 根据部门查询
//     * @param deptIds /
//     * @return /
//     */
//    @Query(value = "SELECT count(1) FROM sys_user u WHERE u.dept_id IN ?1", nativeQuery = true)
//    int countByDepts(Set<Long> deptIds);
//
//    /**
//     * 根据角色查询
//     * @param ids /
//     * @return /
//     */
//    @Query(value = "SELECT count(1) FROM sys_user u, sys_users_roles r WHERE " +
//            "u.user_id = r.user_id AND r.role_id in ?1", nativeQuery = true)
//    int countByRoles(Set<Long> ids);


    /**
     * 根据手机号查找
     * @param phone
     * @return
     */
//    User findByPhone(String phone);

//    /**
//     * 根据类型查找 司机或者车主
//     * @param phone
//     * @param userType
//     * @return
//     */
//    User findByPhoneAndUserType(String phone, Integer userType);
//
//    User findUserByPhone(String phone);
//    @Query("select o from User o where o.id=?1")
//    User findUserById(Long id);
//
//    User findUserByPhoneAndUserType(String phone, Integer userType);

}
